### 數位電路設計

# Lab3 - 同步循序電路之 HDL 模組撰寫與測試

### 1. 目標(Goal)

在這次 Lab 中,我們希望同學們可以熟悉同步循序電路的設計原理,以 state-diagram-based model 與 structural model 等不同方式撰寫其 Verilog HDL 電路模組,並撰寫測試模組。分別模擬後,繳交模組檔案與波形圖。

The main purpose of this Lab Unit is to be familiar with the design of a synchronous sequential circuit. Please write the Verilog HDL circuit modules by state-diagram-base model and structural model, and write the testbench for these circuit modules. After simulation, upload the files of the modules and the waveforms of the simulation results.

### 2. 撰寫 HDL 電路模組與測試模組(Design of the HDL

# **Circuit Modules and Testbench)**

下圖為一 Moore-type sequence detector 之狀態圖(state diagram)與電路圖:

The state diagram and circuit diagram of a Moore-type sequence detector are shown in the following figure:



圖 1: — moore-type sequence detector 之(a)狀態圖與(b)電路圖

Figure 1: The (a) state diagram and (b) circuit diagram of a Moore-type sequence detector.

A. 請根據此電路之狀態圖(圖 1a),以 State-diagram-based model 方式撰寫其 Verilog HDL 電路模組。假設此電路圖有 reset 輸入訊號,可設定電路至初始狀態 00。模組名稱與 port list 請訂為 Lab3\_Moore\_state\_diagram(output y, input x, clock, reset),檔案則請命名為 Lab3\_Moore\_state\_diagram.v。

According to the state diagram shown in Figure 1(a), write the Verilog circuit module for this synchronous sequential circuit by state-diagram-based model. Assume that this circuit can be reset to its initial state 00 by input signal *reset*. The circuit module and port list should be named as Lab3\_Moore\_state\_diagram(output y, input x, clock, reset), and its file should be named as Lab3\_Moore\_state\_diagram.v.

B. 請根據此電路之電路圖(圖 1b),以 Structural model 方式撰寫其 Verilog HDL 電路模組。假設此電路圖有 reset 輸入訊號,可設定電路至初始狀態 00。模組名稱與 port list 請訂為 Lab3\_Moore\_structural(output y, input x, clock, reset),檔案則請命名為 Lab3\_Moore\_structural.v。請注意,此電路模組中需要用到有 asynchronous reset 之 D flip-flop 之電路模組,檔案請命名為 D\_ff\_AR.v。

According to the circuit diagram shown in Figure 1(b), write the Verilog circuit module for this synchronous sequential circuit by structural model. Assume the circuit can be reset to its initial state 00 by input signal reset. The module list should be circuit and named port as Lab3\_Moore\_structure(output y, input x, clock, reset), and its file should be named asLab3\_Moore\_structure.v . Note that this circuit module requires to instantiate the circuit module of a D flip-flop with asynchronous reset. The file of the D flip-flop should be named as D\_ff\_AR.v.

C. 請撰寫一測試模組來測試上述兩個電路模組。請將此測試模組命名為 t\_Lab3\_Moore,檔案則請命名為 t\_Lab3\_Moore.v。

Please write a testbench to test the two circuit modules designed above. The testbench module should be named as t\_Lab3\_Moore, and its file should be named as t\_Lab3\_Moore.v.

#### \* 注意事項:

- 請用 ModelSim Student Edition 10.4a 做為開發環境。 Develop your lab in ModelSim Student Edition 10.4.a.
- 請務必依照上述各項目之規定命名模組及檔案。 Be sure to name the modules and files as described above.
- 禁止抄襲,違者(抄襲者與被抄襲者)以 0 分計算。 Any assignment work by fraud will get a zero point.
- 助教會以其他測資去測試上述作業。

  TA will use similar testbench modules with different test data to verify the correctness of your design of the Verilog circuit modules.

### 3. 作業及 HDL 模組繳交(Hand in)

A. 作業報告繳交:word 檔,命名為 Lab3\_學號\_姓名 包含下列項目:

Hand in a word file, named Lab3\_StudentID\_Name, including the following items:

(1) 2C 之模擬結果波形圖,並說明此 testbench 如何設計、針對 input stimulus 預期之狀態轉換與輸出值為何、及 2A 與 2B 兩種電路模組之模擬結果波形圖是否正確。

Give the waveform of the simulation results in 2C, explain how you design your testbench, show the state transitions and outputs for the input stimuli, and determine whether the circuit modules of 2A and 2B designed by you are correct or not.

(2) 心得與感想、及遭遇到的問題或困難
Describe what you have learned from this lab unit and discuss the problems or difficulties encountered in this lab.

#### B. Verilog modules 檔案繳交: 4 files

Lab3\_Moore\_diagram.v \\
Lab3\_Moore\_structural.v \\
\tab3\_Moore.v

#### Hand in the following Verilog modules: 4 files

Lab3\_Moore\_state\_diagram.v \
Lab3\_Moore\_structure.v \cdot D\_ff\_AR.v \cdot
t\_Lab3\_Moore.v

### 4. DEADLINE

- 本實驗單元為一人一組, 作業請上傳至 E3 平台。
  This lab unit is one student per group. Please upload your Lab Report (word file) and the corresponding HDL code (.v files) onto e-Campus platform.
- 作業繳交截止日期為 2016/6/5 (日) 23:59。不接受逾期繳交。提前於 2016/6/2 (四) 23:59PM 前完成繳交者加分 10% The deadline for handing in lab report and Verilog files is 2016/6/5 (Sunday) 23:59. No late hand-in is allowed. (Early submission before 2016/6/2 23:59PM may earn 10% bonus.)
- 請將上述作業報告及 Verilog 電路模組與測試模組檔案(.v)全部壓縮成一個 zip 檔 (禁止上傳 rar 檔或是其他檔案格式),並以「Lab3\_學號\_姓名」的方式命名,如 : 「Lab3\_0416000\_王大明」。
  Please compress the word file of lab report and the Verilog circuit modules and testbench described above all into one zip file (rar file or other format is not accepted), and name the zip file as "Lab3\_StudentID\_Name", for example, "Lab3\_0416000\_Kent Chang"
- 上機演示 Demo 時間暫定為 6/7 (二) 6:00PM~9:30PM、6/8 (三) 1:00PM~4:30PM, 之後會再發公告通知大家上網填寫 Demo 時間表。 The time for on-line demo is arranged at 6/7 (Tue.) 6:00PM~9:30PM、6/8 (Wed.) 1:00PM~4:30PM tentatively, and we will send an announcement to inform you to fill the Demo schedule online.
- 程式碼請勿抄襲別人或讓別人抄襲,經查證後此次 lab 總分一律以 0 分計算。

Any assignment work by fraud will get a zero point